<!DOCTYPE html>
<html lang=''>

<head>
  <meta charset='UTF-8'>
  <meta http-equiv='X-UA-Compatible' content='IE=edge'>
  <meta name='viewport' content='width=device-width, initial-scale=1.0'>
  <title>Document</title>
  <script src='./vue.js'></script>
  <style>
    html,
    body,
    #app {
      width: 100%;
      height: 100%;
      margin: 0;
      padding: 0;
    }

    .mask {
      position: absolute;
      left: 0;
      top: 0;
      right: 0;
      bottom: 0;
      background-color: #000;
      opacity: 0.5;
    }

    .mask section {
      width: 300px;
      height: 150px;
      background-color: white;
      margin: 200px auto;
      line-height: 150px;
      text-align: center;
    }
  </style>
</head>

<body>
  <div id='app'>
    <button @click="isShow = !isShow"> 点击弹出 </button>

    <!--
      teleport: 是用来做传送用的，to 属性是指定我们将内容模板传送到什么地方去，该属性可以是标签
      名称也可以是对应 id ，不仅可以传送到 app 中的任意位置，也可以传送到 app 的外部任意位置
     -->
    <teleport to='#bpp'>
      <div class="mask" v-if="isShow">
        <section> 这个是抽奖广告 </section>
      </div>
    </teleport>


  </div>


  <div id="bpp"></div>
</body>
<script>
  const app = Vue.createApp({
    data () {
      return {
        isShow: false
      }
    },
  })
  app.mount('#app')
</script>

</html>
